/*
 * @Description:
 * @Version: 1.0
 * @Author: Shi Hexiang
 * @Date: 2023-09-20 16:12:34
 * @LastEditors: Shi Hexiang
 * @LastEditTime: 2023-09-26 17:13:15
 */
/**
 * v-auth
 * 按钮权限指令
 */
import { useAuthStore } from "@/stores/modules/auth"
import type { Directive, DirectiveBinding } from "vue"

const auth: Directive = {
  mounted(el: HTMLElement, binding: DirectiveBinding) {
    const { value } = binding
    const authStore = useAuthStore()
    const currentPageRoles = authStore.authButtonListGet ?? []
    if (value instanceof Array && value.length) {
      const hasPermission = value.every(item => currentPageRoles.includes(item))
      if (!hasPermission) el.remove()
    } else {
      if (!currentPageRoles.includes(value)) el.remove()
    }
  }
}

export default auth
